package leetcode;

import java.util.ArrayList;
import java.util.List;

public class Lc77 {

    List<List<Integer>> ans;

    public List<List<Integer>> combine(int n, int k) {
        ans = new ArrayList<>();
        getAns(n, k, 1, new ArrayList<Integer>());
        return ans;
    }

    public void getAns(int n, int k, int start, List list) {
        if (list.size() == k) {
            ans.add(new ArrayList<>(list));
            return;
        }
        for (int i = start; i <= n - k + list.size() + 1; i++) {
            list.add(i);
            getAns(n, k, i + 1, list);
            list.remove(list.size() - 1);
        }
    }
}
